$(function() {
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
        // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 1,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options)

    //上传图片
    $('#btnChooseImage').on('click', function() {
        $('#file').click(); //模拟点击文件选择
    });

    //获取上传文件
    $('#file').on('change', function(e) {
        let fileList = e.target.files;
        if (fileList.length === 0) {
            return layui.layer.msg('请选择图片');
        }

        let file = e.target.files[0];
        let newImgURL = URL.createObjectURL(file);
        $image
            .cropper('destroy') // 销毁旧的裁剪区域
            .attr('src', newImgURL) // 重新设置图片路径
            .cropper(options); // 重新初始化裁剪区域
    });

    $('#btnUpload').on('click', function() {
        //通过将图片转化成base64编码格式，获取上传的图片
        var dataURL = $image
            .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
                width: 100,
                height: 100
            })
            .toDataURL('image/png'); // 将 Canvas 画布上的内容，转化为 base64 格式的字符串

        //发送请求
        $.ajax({
            type: 'POST',
            url: '/my/update/avatar',
            data: { avatar: dataURL },
            success: function(res) {
                if (res.status !== 0) {
                    return layui.layer.msg(res.message);
                }

                window.parent.getUserInfo();
            },
            timeout: 3000,
            error: function(err) {
                return layui.layer.msg('出错啦');
            }
        });
    });
});